home *** CD-ROM | disk | FTP | other *** search
/ Amiga Magazin: Amiga-CD 1996 September & October / Amiga-CD 1996 #9-10.iso / demos / storm-c / stormwizard / example-source / c-source / simple / snapshot / snapshot.c < prev    next >
Encoding:
C/C++ Source or Header  |  1996-06-18  |  3.6 KB  |  126 lines

  1. /* Snapshot - Speichern der aktuellen Fensterpositionen
  2.  
  3.    (geschrieben unter StormC V1.1)
  4.  
  5.    $VER:              1.0 (12.06.96)
  6.  
  7.    Autor:             Thomas Mittelsdorf
  8.  
  9.    © 1996 HAAGE & PARTNER Computer GmbH,  All Rights Reserved
  10.  
  11. */
  12.  
  13. #include    <stdio.h>
  14.  
  15. #include    <clib/alib_protos.h>
  16.  
  17. #include    <pragma/exec_lib.h>
  18. #include    <pragma/intuition_lib.h>
  19. #include    <pragma/utility_lib.h>
  20. #include    <pragma/wizard_lib.h>
  21.  
  22. #include    <libraries/wizard.h>
  23. #include    <intuition/gadgetclass.h>
  24. #include    <intuition/intuition.h>
  25.  
  26. #include    "snapshot.h"
  27.  
  28. APTR    surface;
  29. struct Screen    *screen;
  30. struct NewWindow *newwin;
  31. struct Window    *window;
  32. struct WizardWindowHandle *winhandle;
  33. struct Gadget *gads[WINDOW_MAIN_GADGETS];
  34.  
  35. void main( void)
  36. {
  37.     BOOL Flag;
  38.  
  39.     struct IntuiMessage *msg;
  40.  
  41.  
  42.     // Erstmal die Oberflächenbeschreibung bereitstellen!
  43.     if ((surface=WZ_OpenSurface("snapshot.wizard",0L,TAG_DONE)))
  44.     {
  45.  
  46.         // Natürlich brauchen wir auch einen Screen oder?
  47.         if ((screen=LockPubScreen(0L)))
  48.         {
  49.  
  50.             // Jetzt holen wir uns ein WindowHandle, mit dem unsere Objekte
  51.             // durch die wizard.library verwaltet werden.
  52.             if ((winhandle=WZ_AllocWindowHandle(screen,0L,surface,TAG_DONE)))
  53.             {
  54.  
  55.                 // Da ein WindowHandle nur Sinn macht, wenn auch die Objekte
  56.                 // darin vorkommen, legen wir diese Objekte jetzt an.
  57.                 if ((newwin=WZ_CreateWindowObj(winhandle,WINDOW_MAIN,WWH_GadgetArray,gads,
  58.                                                                                             WWH_GadgetArraySize,sizeof(gads),
  59.                                                                                             TAG_DONE)))
  60.                 {
  61.  
  62.                     // Nachdem das glatt ging, versuchen wir unser
  63.                     // Fenster zu öffnen. Dabei werden alle Objekte installiert.
  64.                     // Das Tag WA_AutoAdjust besagt, das unter Umständen das
  65.                     // Betriebssystem unsere Fensterposition und Dimension
  66.                     // korrigieren darf.
  67.                     if ((window=WZ_OpenWindow(winhandle,newwin,WA_AutoAdjust,TRUE,
  68.                                                                             TAG_DONE)))
  69.                     {
  70.                         Flag=TRUE;    // Flag zum Beenden der nachfolgenden Schleife
  71.  
  72.                         do
  73.                         {
  74.                             // Da wir keine Rechenzeit verschwenden wollen, werden wir
  75.                             // das Program "schlafen" legen, bis eine Nachricht
  76.                             // eintifft. Für Profis gilt, das auch Wait() verwendet
  77.                             // werden kann.
  78.                             WaitPort(window->UserPort);
  79.  
  80.                             if ((msg=(struct IntuiMessage *)GetMsg(window->UserPort)))
  81.                             {
  82.                                 // Ha, da ist doch tatsächlich eine Nachricht ange-
  83.                                 // kommen. Na dann gucken wir mal ob Sie auch vom
  84.                                 // richtigen Type ist.
  85.  
  86.                                 if (msg->Class==IDCMP_CLOSEWINDOW)
  87.                                     Flag=FALSE;
  88.  
  89.                                 // Da wir keine Speicherleichen dulden und
  90.                                 // das Nachrichtensystem nicht durcheinanden bringen
  91.                                 // wollen, teilen wir den Betriebssystem mit, das
  92.                                 // die Nachricht von uns nicht mehr benötigt wird.
  93.                                 ReplyMsg((struct Message *)msg);
  94.                             }
  95.                         }
  96.                         while (Flag);
  97.  
  98.                         // Fenster schließen
  99.                         WZ_CloseWindow(winhandle);
  100.                     }
  101.                 }
  102.  
  103.                 // In jedem Fall muß ein mit WZ_AllocWindowHandle() angelegter
  104.                 // WindowHandle auch wieder freigegeben werden. Übrigens
  105.                 // kann das Fenster hierbei noch offen sein. Probieren Sie es!
  106.                 WZ_FreeWindowHandle(winhandle);
  107.             }
  108.  
  109.             // PublicScreen-Benutzerzähler wieder um eins verringern
  110.             UnlockPubScreen(0L,screen);
  111.         }
  112.  
  113.         // Da es bei diesem Beispiel auf die SnapShot-Funktion ankommt, werden
  114.         // wir diese an dieser Stelle auch aufrufen.
  115.         // ACHTUNG:
  116.         // Alle WindowHandles müssen beim Aufruf dieser Funktion geschlossen
  117.         // sein.
  118.         WZ_SnapShot(surface,TAG_DONE);
  119.  
  120.         // Da wir keine Objekte von dieser Surface mehr besitzen und wir diese
  121.         // auch nicht mehr anlegen geben wir sie frei. Übrigens noch
  122.         // nicht freigegebene WindowHandles werden hierbei von der
  123.         // wizard.libarry entfernt (Fenster auch geschlossen).
  124.         WZ_CloseSurface(surface);
  125.     }
  126. }